package com.ruoyi.system.mapper;

import java.util.List;

import com.alibaba.fastjson.JSONObject;
import com.ruoyi.system.domain.ByParam;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Param;
import org.apache.ibatis.annotations.Select;

/**
 * 项目参数Mapper接口
 *
 * @author ruoyi
 * @date 2023-06-14
 */
@Mapper
public interface ByParamMapper {

    @Select("SELECT * FROM `by_param` where id = #{id}")
    JSONObject getParamJSONObjectById(@Param("id") String id);

    @Select("SELECT * FROM `by_param` where pid = #{pid} order by id")
    List<JSONObject> getParamByPid(@Param("pid") String pid);

    @Select("SELECT *,'0' status FROM `by_param` where pid = #{pid} order by id")
    List<JSONObject> getParamStatusByPid(@Param("pid") String pid);


    /**
     * 查询项目参数
     *
     * @param id 项目参数主键
     * @return 项目参数
     */
    public ByParam selectByParamById(Long id);

    /**
     * 查询项目参数列表
     *
     * @param byParam 项目参数
     * @return 项目参数集合
     */
    public List<ByParam> selectByParamList(ByParam byParam);

    /**
     * 新增项目参数
     *
     * @param byParam 项目参数
     * @return 结果
     */
    public int insertByParam(ByParam byParam);

    /**
     * 修改项目参数
     *
     * @param byParam 项目参数
     * @return 结果
     */
    public int updateByParam(ByParam byParam);

    /**
     * 删除项目参数
     *
     * @param id 项目参数主键
     * @return 结果
     */
    public int deleteByParamById(Long id);

    /**
     * 批量删除项目参数
     *
     * @param ids 需要删除的数据主键集合
     * @return 结果
     */
    public int deleteByParamByIds(Long[] ids);
}
